package com.example.blog.mapper;

import java.util.Date;
import java.util.List;

import org.apache.ibatis.annotations.Param;

import com.example.blog.entity.LoginLog;

public interface LoginLogMapper {
    /**
     * 通过日志ID查询
     */
    LoginLog selectByPrimaryKey(Integer logId);
    
    /**
     * 查询所有登录日志
     */
    List<LoginLog> selectAll();
    
    /**
     * 通过用户ID查询登录日志
     */
    List<LoginLog> selectByUserId(Integer userId);
    
    /**
     * 通过登录状态查询日志
     */
    List<LoginLog> selectByLoginStatus(String loginStatus);
    
    /**
     * 通过时间范围查询日志
     */
    List<LoginLog> selectByTimeRange(@Param("startTime") Date startTime, @Param("endTime") Date endTime);
    
    /**
     * 插入登录日志记录
     */
    int insert(LoginLog loginLog);
    
    /**
     * 删除登录日志记录
     */
    int deleteByPrimaryKey(Integer logId);
    
    /**
     * 删除用户的所有登录日志
     */
    int deleteByUserId(Integer userId);
    
    /**
     * 清理特定日期之前的登录日志
     */
    int deleteBeforeDate(Date date);
} 